package com.xinke.module.system.model.entity.user;

import com.baomidou.mybatisplus.extension.handlers.JacksonTypeHandler;
import com.xinke.component.tenant.core.db.TenantBaseDO;
import lombok.*;
import java.util.*;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import java.time.LocalDateTime;
import com.baomidou.mybatisplus.annotation.*;
import com.xinke.component.mybatis.mybatis.core.dataobject.BaseDO;

/**
 * 用户信息 DO
 *
 * @author yzx
 */
@TableName(value = "system_users", autoResultMap = true)
@KeySequence("system_users_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库，可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class AdminUserDO extends TenantBaseDO {

    /**
     * 用户ID
     */
    @TableId
    private Long userId;
    /**
     * 用户账号
     */
    private String userName;
    /**
     * 密码
     */
    private String userPassword;
    /**
     * 用户昵称
     */
    private String userNickName;
    /**
     * 部门ID
     */
    private Long deptId;
    /**
     * 岗位编号数组
     */
    @TableField(typeHandler = JacksonTypeHandler.class)
    private Set<Long>  postIds;
    /**
     * 用户邮箱
     */
    private String userEmail;
    /**
     * 手机号码
     */
    private String userPhone;
    /**
     * 用户性别
     */
    private Integer userSex;
    /**
     * 头像地址
     */
    private String userAvatar;
    /**
     * 帐号状态（1正常 0停用）
     */
    private Integer userStatus;
    /**
     * 最后登录IP
     */
    private String loginIp;
    /**
     * 最后登录时间
     */
    private LocalDateTime loginDate;
    /**
     * 备注
     */
    private String remark;

}